<script setup lang="ts">
import { useRouter } from 'vue-router'

const router = useRouter()
// #1 点击左侧返回
const onClickLeft = () => {
  // 判断历史记录中是否有回退记录
  if (history.state?.back) {
    router.back()
  } else {
    router.push('/')
  }
}

// #2 接收 title 和 rightText
defineProps<{
  title?: string
  rightText?: string
}>()

// #3 右侧的点击，让外界决定做什么事情
const emit = defineEmits<{
  (e: 'click-right'): void
}>()
const onClickRight = () => {
  emit('click-right')
}
</script>

<template>
  <van-nav-bar
    left-arrow
    @click-left="onClickLeft"
    fixed
    :title="title"
    :right-text="rightText"
    @click-right="onClickRight"
  ></van-nav-bar>
</template>

<style scoped lang="scss">
/* /deep/
::v-deep
>>> */
// 样式穿透：不同的css编译器有不同的格式.
//          less, scss
::v-deep() {
  .van-nav-bar {
    &__arrow {
      font-size: 18px;
      color: var(--cp-text1);
    }

    &__text {
      font-size: 15px;
    }
  }
  .van-nav-bar__title {
    font-weight: normal;
  }
}
</style>
